<template>
  <div>
    <el-form :inline="true" class="demo-form-inline">
      <el-form-item>
        <el-button type="primary" @click="addRole">添加角色</el-button>
      </el-form-item>
    </el-form>
    <el-table :data="data.list" border style="width: 100%">
      <el-table-column prop="roleId" label="ID" width="180" />
      <el-table-column prop="roleName" label="角色名" width="180" />
      <el-table-column prop="authority" label="操作">
        <template #default="scope">
          <el-button size="small" type="primary" @click="changeRole(scope.row)">
            修改权限
          </el-button>
        </template>
      </el-table-column>
    </el-table>
  </div>
</template>

<script setup lang="ts">
import { getRoleList } from '@/request/api'
import { onMounted, reactive } from 'vue'
import { InitData, type ListInt } from '../type/role'
import { ElMessage, ElMessageBox } from 'element-plus'
import 'element-plus/es/components/message/style/css'
import { useRouter } from 'vue-router'

const data = reactive(new InitData())
const router = useRouter()

const getRole = () => {
  getRoleList()
    .then((res) => {
      console.log(res)
      data.list = res.data
    })
    .catch(() => {})
}

const addRole = () => {
  ElMessageBox.prompt('请输入角色名称', '添加', {
    confirmButtonText: '确定',
    cancelButtonText: '取消'
  })
    .then(({ value }) => {
      if (value) {
        data.list.push({ roleId: data.list.length + 1, roleName: value, authority: [] })
      }
      ElMessage({
        type: 'success',
        message: `${value}角色添加成功`
      })
    })
    .catch(() => {
      ElMessage({
        type: 'info',
        message: '取消操作'
      })
    })
}

const changeRole = (row: ListInt) => {
  router.push({
    name: 'authority',
    query: {
      id: row.roleId,
      authority: row.authority.toString()
    }
  })
}

onMounted(() => {
  getRole()
})
</script>
